<template>
  <div class="xtx-pagination">
    <a @click="changePager(myCurrentPage-1)" v-if="myCurrentPage>1" href="javascript:;">上一页</a>
    <a v-else href="javascript:;" class="disabled">上一页</a>
    <span v-if="pager.start>1">...</span>
    <a @click="changePager(myCurrentPage=i)" href="javascript:;" v-for="i in pager.btnArr" :key="i" :class="{active:i===myCurrentPage}">{{i}}</a>
    <span v-if="pager.end<pager.pageCount">...</span>
    <a @click="changePager(myCurrentPage+1)" v-if="myCurrentPage<pager.pageCount" href="javascript:;">下一页</a>
    <a v-else href="javascript:;" class="disabled">下一页</a>
  </div>
</template>
<script>
import { computed, ref, watch } from 'vue-demi'
export default {
  name: 'XtxPagination',
  props:{
    // 总条数
    total:{
      type:Number,
      default:100
    },
    // 每页条数
    PageSize:{
      type:Number,
      default:10
    },
    // 当前显示的页码
    CurrentPage:{
      type:Number,
      default:1
    }
  },
  setup (props,{emit}) {
    // 总条数，测试数据：101  9
    const myTotal = ref(100)
    // 每页条数
    const myPageSize = ref(10)
    // 当前第几页，测试数据： 1 5 11
    const myCurrentPage = ref(1)
    // 按钮个数
    const btnCount = ref(5)

    // 重点：根据上述数据得到（总页数，起始页码，结束页码，按钮数组）
    const pager = computed(() => {
      // 计算总页数
      const pageCount = Math.ceil(myTotal.value / myPageSize.value)
      // 计算起始页码和结束页码
      // 1. 理想情况根据当前页码，和按钮个数可得到
      let start = myCurrentPage.value - Math.floor(btnCount.value / 2)
      // 2.1 如果起始页码小于1了，需要重新计算
      if (start < 1) start = 1

      let end = start + btnCount.value - 1
      // 2.2 如果结束页码大于总页数，需要重新计算
      if (end > pageCount) {
        end = pageCount
        start = end - btnCount.value + 1
        if (start < 1) start = 1
      }
      // 处理完毕start和end得到按钮数组
      const btnArr = []
      for (let i = start; i <= end; i++) {
        btnArr.push(i)
      }
      return { pageCount, start, end, btnArr }
    })

    //监听props的变化，更新组件内部数据
    watch(props,()=>{
      // console.log('变化了');
      myTotal.value=props.total
      myCurrentPage.value=props.CurrentPage
      myPageSize.value=props.PageSize
    },{immediate:true})

    //切换分页的函数
    const changePager=(page)=>{
      myCurrentPage.value=page
      //通知父组件
      emit('current-change',page)
    }
    return { pager, myCurrentPage,changePager}
  }
}
</script>
<style scoped lang="less">
.xtx-pagination {
  display: flex;
  justify-content: center;
  padding: 30px;
  > a {
    display: inline-block;
    padding: 5px 10px;
    border: 1px solid #e4e4e4;
    border-radius: 4px;
    margin-right: 10px;
    &:hover {
      color: @xtxColor;
    }
    &.active {
      background: @xtxColor;
      color: #fff;
      border-color: @xtxColor;
    }
    &.disabled {
      cursor: not-allowed;
      opacity: 0.4;
      &:hover {
        color: #333
      }
    }
  }
  > span {
    margin-right: 10px;
  }
}
</style>
